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DETAILED ACTION 

1. Claims 1 and 4-12 have been considered Claims 1 and 1 1 are amended as per 
Applicant's request. Claims 2-3 have been cancelled as per AppHcant's request. 

Papers Submitted 

2. It is hereby acknowledged that the following papers have been received and placed of 
record in the file: Amendment as received on 30 September 2004; RCE as received on 12 
October 2004; and IDS as received on 04 November 2004. 

Claim Rejections - 35 USC §103 

3. The following is a quotation of 35 U.S.C. 103(a) which forms the basis for all 
obviousness rejections set forth in this Office action: 

(a) A patent may not be obtained though the invention is not identically disclosed or described as set forth in 
section 102 of this title, if the differences between the subject matter sought to be patented and the prior art are 
such that the subject matter as a whole would have been obvious at the time the invention was made to a person 
having ordinary skill in the art to which said subject matter pertains. Patentability shall not be negatived by the 
manner in which the invention was made. 

4. Claims 1-9 and 1 1 are rejected under 35 U.S.C. 103(a) as being unpatentable over 
Suzuki, U.S. Patent Number 6,499,096 (herein referred to as Suzuki) in view of Kahle et al., U.S. 
Patent Number 5,913,925 (herein referred to as Kahle). 

5. Referring to claim 1, Suzuki has taught a data-processing device for processing in parallel 
a plurality of processes, comprising: 

a. A multiplicity of bundles with a plurality of instructions of a process, the 
instructions of a bundle being executable in parallel (Suzuki column 2, lines 14- 
29); 

b. A branching control unit connected to and addressing said program memory a 
register for storing flags and data which are switched in dependence on a process 
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being executed (Suzuki column 6, lines 29-44 and 52-67; column 12, line 36 to 
column 13, line 5; Figure 3; and Figure 11); 

c. A program flow control unit connected to said branching control unit (Suzuki 
column 6, lines 29-44 and 52-67 and Figure 3), said program flow control unit 
controlling a fetching of bundles to be processed in parallel from said program 
memory, controlling said branching control unit, and controlling an output of 
instructions to be processed in parallel in dependence on information contained in 
the instructions and included in a compiling time of the program (Suzuki column 

6, lines 29-44 and 52-67 and Figure 3); 

d. A number N of instruction buffers being connected in parallel downstream of said 
program memory for storing instructions read out from said program memory 
(Suzuki column 4, line 56 to column 5, line 6; column 12, lines 7-13; column 12, 
line 36 to column 13, line 5; Figure 3; Figure 9; and Figure 1 1), an instruction 
bundle being read into one of said instruction buffers and a second instruction 
bundle associated with a different process being read into another one of said 
instruction buffers(Suzuki column 4, line 56 to column 5, line 6; column 12, lines 
7-13; column 12, line 36 to column 13, line 5; Figure 3; Figure 9; and Figure 1 1); 
and 

e. An instruction output selector being connected to and controlled by said process 
flow control unit causing said instruction output selector to read out instructions 
from said instruction buffers and output N instructions in parallel (Suzuki column 

7, line 62 to column 8, line 24; column 12, line 36 to column 13, line 6; Figure 3; 
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and Figure 1 1), said instruction output selector having a multiplexer logic and 
selecting one of either one instruction from a first instruction buffer and one 
instruction from a second instruction buffer, or two instructions from one of said 
first and second instruction buffers (Suzuki column 7, line 62 to column 8, line 
24; column 12, line 36 to column 13, line 6; Figure 3; and Figure 1 1). 

6. Suzuki has not taught a program memory having stored therein at least one compiled 
program with a multiplicity N of independent processes, the compiled program including 
information on parallelism. Kahle has taught A program memory having stored therein at least 
one compiled program with a multiplicity N of independent processes, the compiled program 
including information on parallelism (Kahle column 2, lines 64 to column 3, line 2; column 4, 
lines 33-46; and Figure 1 A). A person of ordinary skill in the art at the time the invention was 
made that the multiscalar device of Kahle utilizes more of the hardware resources and diminishes 
the effects of mispredicted branches and data dependencies between tasks (Kahle column 3, lines 
59-66), thereby improving processor performance. Therefore, it would have been obvious to a 
person of ordinary skill in the art at the time the invention was made to incorporate the 
multiscalar device of Kahle in the device of Suzuki to improve processor performance. 

7. Referring to claim 4, Suzuki has taught which comprises N instruction decoders for 
decoding the instructions being output (Suzuki column 4, line 56 to column 5, line 6; column 12, 
lines 7-13; column 12, line 36 to column 13, line 5; Figure 3; Figure 9; and Figure 1 1). 

8. Referring to claim 5, Suzuki has taught which comprises at least two instruction- 
execution units for outputting the N decoded instructions (Suzuki column 4, line 56 to column 5, 
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line 6; column 12, lines 7-13; column 12, line 36 to column 13, line 5; Figure 3; Figure 9; and 
Figure 11). 

9. Referring to claim 6, Suzuki has not taught which comprises a data memory and at least 
two buses connecting said N instruction-execution units to said data memory. Kahle has taught 
which comprises a data memory and at least two buses connecting said N instruction-execution 
units to said data memory (Kahle column 10, lines 26-33 and Figure 4). A person of ordinary 
skill in the art at the time the invention was made that the multiscalar device of Kahle utilizes 
more of the hardware resources and diminishes the effects of mispredicted branches and data 
dependencies between tasks (Kahle column 3, lines 59-66), thereby improving processor 
performance. Therefore, it would have been obvious to a person of ordinary skill in the art at the 
time the invention was made to incorporate the multiscalar device of Kahle in the device of 
Suzuki to improve processor performance. 

10. Referring to claim 7, Suzuki has taught which comprises a plurality of instruction- 
execution units connected to said program flow control unit and configured to execute the 
instructions of one or more bundles in parallel (Suzuki column 4, line 56 to column 5, line 6; 
column 12, lines 7-13; column 12, line 36 to column 13, line 5; Figure 3; Figure 9; and Figure 
11). 

1 1 . Referring to claim 8, Suzuki has taught wherein said branching control unit is configured 
to output an address pointer for addressing a bundle (Suzuki column 6, lines 29-44 and 52-67; 
column 12, line 36 to column 13, line 5; Figure 3; and Figure 1 1). 

12. Referring to claims 9 and 11, Suzuki has taught wherein the branching control unit 
comprises: 
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a. A first multiplexer and a second multiplexer (Applicant's claim 9) (Suzuki 
column 6, lines 29-44 and 52-67; column 12, line 36 to column 13, line 5; Figure 
3; and Figure 11); 

b. An adder (Applicant's claim 9) (Suzuki column 6, lines 29-44 and 52-67; column 
12, line 36 to column 13, line 5; Figure 3; and Figure 1 1); 

c. Wherein said program flow control unit feeds a number of instructions in a bundle 
to said adder and siaid adder adds an address pointer and the number of 
instructions (Applicant's claim 9) (Suzuki column 6, lines 29-44 and 52-67; 
column 12, line 36 to column 13, line 5; Figure 3; and Figure 1 1); 

d. Wherein said program flow control unit feeds addresses for program jumps or 
function calls and a process number to said first multiplexer (Applicant's claim 9) 
(Suzuki column 6, lines 29-44 and 52-67; column 12, line 36 to column 13, line 5; 
Figure 3; and Figure 11); 

e. Said first multiplexer writing either the output signal of said adder or the 
addresses for program jumps or function calls into said program counter assigned 
to the active process (Applicant's claim 9) (Suzuki column 6, lines 29-44 and 52- 
67; column 12, Hne 36 to column 13, line 5; Figure 3; and Figure 1 1); and 

f A content of said program counter assigned to the currently active process is 

output as a new address pointer via said, second multiplexer which is controlled 
using the process number supplied (Apphcant's claim 9) (Suzuki column 6, lines 
29-44 and 52-67; column 12, line 36 to column 13, line 5; Figure 3; and Figure 
11). 
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g. Wherein said program flow control unit is configured to receive via a subbus of 
an output bus of said program memory at least one of the following: 

i. At least one bit for indicating the parallel execution of instructions 
(Applicant's claim 10) (Suzuki column 2, lines 14-29). In regards to 
Suzuki, the at least one bit is inherent for the instruction to be recognized 
as a VLIW instruction. 

ii. At least one bit for indicating the length of the following instruction 
bundle (Applicant's claim 10) (Suzuki column 4, Hne 56 to column 5, line 
6; column 12, lines 7-13; column 12, line 36 to column 13, line 5; Figure 
3; Figure 9; and Figure 11). In regards to Suzuki, the at least one bit is 
inherent for the instruction to recognize where it ends, since the 
instructions contains multiple sub-instructions. 

iii. The indication of one or more NOPs in the instruction bundles 
(Applicant's claim 10) (Suzuki column 3, lines 49-52). 

1 3 . Suzuki has not taught 

a. N program counters (AppUcant's claim 9); 

b. A priority of the processes of the instructions (Applicant's claim 10); 

c. Wherein a process is called with a run instruction assigning a process number, a 
priority and a memory address of a starting point of the process in the program 
memory (Applicant's claim 11). 

14. Kahle has taught 
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a. N program counters (Applicant's claim 9) (Kahle column 10, lines 26-33 and 
Figure 4); 

b. A priority of the processes of the instructions (Applicant's claim 10) (Kahle 
column 10, line 52 to column 11, line 29) 

c. Wherein a process is called with a run instruction assigning a process number, a 
priority and a memory address of a starting point of the process in the program 
memory (Applicant's claim 1 1) (Kahle column 10, line 52 to column 1 1, line 29). 

15. The program counters are inherent, since the position of the instruction for each thread in 
the individual instruction caches must be known. Program counters indicate which instruction is 
to executed next. A person of ordinary skill in the art at the time the invention was made that the 
muhiscalar device of Kahle utilizes more of the hardware resources and diminishes the effects of 
mispredicted branches and data dependencies between tasks (Kahle colunm 3, lines 59-66), 
thereby improving processor performance. Therefore, it would have been obvious to a person of 
ordinary skill in the art at the time the invention was made to incorporate the multiscalar device 
of Kahle in the device of Suzuki to improve processor performance. 

16. Claim 12 is rejected under 35 U.S.C. 103(a) as being unpatentable over Suzuki, U.S. 
Patent Number 6,499,096 (herein referred to as Suzuki) in view of Kahle et al, U.S. Patent 
Number 5,913,925 (herein referred to as Kahle) as appHed to claim 1 above, and further in view 
of Allen, Jr. et al, U.S. Patent No. 6,404,752 (herein referred to as Allen). Suzuki in view of 
Kahle has not explicitly taught wherein said data processing device is a network processor for 
processing layer 1 to 7 of protocol stacks in applications including LAN, ATM switches, IP 
routers, and frame relays based on a system selected from the group consisting of DSL, Ethernet, 
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and cable modems. Allen has taught the use of general-purpose microprocessors as network 
processors to provide a cost-effective solution to processing protocol stack layers for IDSN, 
cable and DSL modems that provides high throughput and speeds (Allen column 1, lines 44-49 
and column 2, line 38 to column 3, line 23). One of ordinary skill in the art would have 
recognized that a primary goal in microprocessor design is to lower costs while maintaining a 
high level of performance. Therefore, one of ordinary skill in the art would have found it 
obvious to modify the processor of Gupta to be used in a network processor because Gupta has 
taught a high-performance, general-purpose processor (see Col.5 lines 62-65), thus allowing 
costs to be kept low while providing a high level of network processing performance. 

Response to Arguments 

17. Applicant's arguments with respect to claims 1 and 4-12 have been considered but are 
moot in view of the new ground(s) of rejection. 

Conclusion 

18. Any inquiry concerning this communication or earlier communications from the 
examiner should be directed to Aimee J Li whose telephone number is (571) 272-4169. The 
examiner can normally be reached on M-T 7:30am-5:00pm. 

19. If attempts to reach the exammer by telephone are unsuccessful, the examiner's 
supervisor, Eddie Chan can be reached on (571) 272-4162. The fax phone number for the 
organization where this application or proceeding is assigned is 703-872-9306. 

20. Information regarding the status of an application may be obtained from the Patent 
Application Information Retrieval (PAIR) system. Status information for published applications 
may be obtained from either Private PAIR or Public PAIR. Status information for unpublished 
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applications is available through Private PAIR only. For more information about the PAIR 
system, see http://pair-direct.uspto.gov. Should you have questions on access to the Private PAIR 
system, contact the Electronic Business Center (EBC) at 866-217-9197 (toll-free). 

AJL 

Aimee J. Li 

21 February 2005 
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